תרגיל בית 6 – יבש 4

זיכרון וירטואלי

שאלה-1:

נחשב את הזמן הממוצע לגישה לזיכרון הורטואלי.

בכל מקרה גם אם נקבל TLB HIT או MISS נשלם תמיד זמן גישה לTLB על מנת למצוא את התרגום זריז בנוסף לגישה לRAM שבה אני ניגשים לזיכרון הפיזי. במידה וקיבלנו TLB MISS נצטרך לשלם כנס שבו המערכת צריכה לגשת לRAM כדי לחפש את התרגום במידה ונמצא סיימנו, במידה וקיבלנו PAGEFAULT או MISS נשלם עוד קנס גישה לDISK על מנת להביא את הPAGE הנכון. ונקבל:

שאלה-2:

1. תהליך 1 מקצה וניגש לPAGE מסוים, בתוך ה-TLB נשמר התרגום. לאחר מכן מתרחשת הפקעה(SWITCH CONTEXT) ותהליך 2 מתחיל לרוץ, עקב חוסר זיכרון מערכת ההפעלה נאלצת להעיף דפים לדיסק, בהינתן שהעברנו דף שנמצא בשימוש אצל תהליך 1 וקיים לו תרגום בתוך טבלת הTLB של תהליך 1. אם נחזיר את תהליך 1 והוא יבקש את אותו דף שתהליך 2 העיף נקבל שגיאה כי התרגום כבר לא חוקי מכיוון שעבור אותה כתובת פיזית כעט נמצא דף אחר ששייך לתהליך מערכת ההפעלה וניגשנו אליו בלא הרשאה מה שיכול להקריס את התוכנית.
2. כדי לגרום לזה לעבוד נצטרך למחוק את השורה בTLB שעוברת פינוי בכל פעם שדף מועף מהזיכרון הראשי.

שאלה-3:

1. לא נכון, לשני התהליכים תהיה אותה כתובת פיסית אבל לכל תהליך קיים מיפוי משלו לכתובת הווירטואלית ולכן לא בהכרח נקבל את אותה הכתובת הווירטואלית בהינתן אותה כתובת פיסית.
2. לא נכון, במקרה של TLB MISS וגם PAGE FAULT נקבל LATENCY גבוה יותר כי נצטרך לעבור יותר גישות עד שנקבל HIT.
3. נכון, ייתכן מצב ובו שני התהליכים בצורה אקראית לגמרי קיבלו את אותה הכתובת הווירטואלית ומופה לאותה כתובת פיסית, למשל כאשר עושים FORK עם זיכרון משותף.
4. נכון, נבצע UNVALIDATE בכל פעם שנעביר תוכן מהזיכרון הראשי לדיסק.
5. נכון, אם נבצע OUT SWAP לדף שבו X מוקצה אצל האב, הבן יקבל FAULT PAGE MAJOR.
6. לא נכון, 3CR היינה כתובת פיזית ואין תרגום כלשהוא בדרך ולכן לא נוכל לקבל FAULT PAGE.
7. לא נכון, אם נחליף בין שני חוטים על אותו תהליך לא נצטרך לשנות את 3CR.
8. נכון, אם שני תהליכים משתמשים באותו דף, ואחד מהם עושה OUT SWAP ואחר כך IN SWAP ה BIT DIRTY יהיה שווה ל0.